Flask can make use of the SQLite3 module of the python to create the database web applications. In this section of the tutorial, we will create a CRUD (create - read - update - delete) application.
Since we have given a detailed overview of how a python application can interact with the SQLite database, to revise the concept, please visit the link: Python SQLite.
Here, we will manage the employee information in the SQLite database using a flask script to which the admin can interact. For this purpose, database employee.db contains the related tables whereas the table Employees contains information about the employees.
First, let us create a database employee.DB and the table Employees in SQLite using the following python script.
EmoloyeeDB.py
1.import sqlite3
2.
3.con = sqlite3.connect("employee.db")
4.print("Database opened successfully")
5.
6.con.execute("create table Employees (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, email TEXT UNIQUE NOT NULL, address TEXT NOT NULL)")
7.
8.print("Table created successfully")
9.
10.con.close()
To build a CRUD application in the flask, we must focus on the view functions (to take the input) and the controllers (to save that data into the database).
Let us look at the view function: index() which is associated with the URL (/). It renders a template index.html.
1.@app.route("/")
2.def index():
3. return render_template("index.html");
The following HTML template (index.html) is considered as the home page of our application. It provides the links using which we can add, view, and delete the data stored in the database.
index.html
1.<!DOCTYPE html>
2.<html>
3.<head>
4. <title>home</title>
5.</head>
6.<body>
7. <h2>Hi, welcome to the website</h2>
8. <a href="/add">Add Employee</a><br><br>
9. <a href ="/view">List Records</a><br><br>
10. <a href="/delete">Delete Record</a><br><br>
11.</body>
12.</html>
The view function add() which is associated with the URL (/add) renders the template add.html given below. It provides the form to enter the employee information.
add.html
1.<!DOCTYPE html>
2.<html>
3.<head>
4. <title>Add Employee</title>
5.</head>
6.<body>
7. <h2>Employee Information</h2>
8. <form action = "/savedetails" method="post">
9. <table>
10. <tr><td>Name</td><td><input type="text" name="name"></td></tr>
11. <tr><td>Email</td><td><input type="email" name="email"></td></tr>
12. <tr><td>Address</td><td><input type="text" name="address"></td></tr>
13. <tr><td><input type="submit" value="Submit"></td></tr>
14. </table>
15. </form>
16.</body>
17.</html>
All the details entered by the Admin is posted to the URL /savedetails which is associated with the function saveDetails(). The function saveDetails() is given below which contains the code for extracting the data entered by the admin and save that data into the table Employees.
It also generates the message depending upon the cases in which the data is successfully inserted, or some error occurred.
1.@app.route("/savedetails",methods = ["POST","GET"])
2.def saveDetails():
3. msg = "msg"
4. if request.method == "POST":
5. try:
6. name = request.form["name"]
7. email = request.form["email"]
8. address = request.form["address"]
9. with sqlite3.connect("employee.db") as con:
10. cur = con.cursor()
11. cur.execute("INSERT into Employees (name, email, address) values (?,?,?)",(name,email,address))
12. con.commit()
13. msg = "Employee successfully Added"
14. except:
15. con.rollback()
16. msg = "We can not add the employee to the list"
17. finally:
18. return render_template("success.html",msg = msg)
19. con.close()
It renders a template success.html to display the message to the admin. It also contains a link to view the records entered by the user.
success.html
1.<!DOCTYPE html>
2.<html>
3.<head>
4. <title>save details</title>
5.</head>
6.<body>
7. <h3>Hi Admin, {{msg}}</h3>
8. <a href="/view">View Employees</a>
9.</body>
10.</html>
The function delete() is associated to the URL /delete. It renders an HTML template delete.html which provides the form to the admin that prompts to enter the Employee_Id of which the records are to be deleted. It also contains a link to the /view URL that shows all the records to the admin.
The HTML template delete.html is given below.
delete.html
1.<!DOCTYPE html>
2.<html>
3.<head>
4. <title>delete record</title>
5.</head>
6.<body>
7.
8. <h3>Remove Employee from the list</h3>
9.
10.<form action="/deleterecord" method="post">
11.Employee Id <input type="text" name="id">
12.<input type="submit" value="Submit">
13.</form>
14.</body>
15.</html>
The Employee_Id entered by the admin is posted to the URL /deleterecord which contains the python code to establish the connection to the database and then delete all the records for the specified Employee ID. The URL /deleterecord is associated with the function deleterecord() which is given below.
1.@app.route("/deleterecord",methods = ["POST"])
2.def deleterecord():
3. id = request.form["id"]
4. with sqlite3.connect("employee.db") as con:
5. try:
6. cur = con.cursor()
7. cur.execute("delete from Employees where id = ?",id)
8. msg = "record successfully deleted"
9. except:
10. msg = "can't be deleted"
11. finally:
12. return render_template("delete_record.html",msg = msg)
The function deleterecord() generates a message depending upon the scenario whether the data is successfully deleted or some error occurred. It renders an HTML template delete_record.html to show the message to the admin.
delete_record.html
1.<!DOCTYPE html>
2.<html>
3.<head>
4. <title>delete record</title>
5.</head>
6.<body>
7.<h3>{{msg}}</h3>
8.<a href="/view">View List</a>
9.</body>
10.</html>
The template delete_record.html contains a link to the URL /view which shows the Employee records to the admin.
It is associated with the function view() which establishes the connection to the database, fetch all the information and pass that information to the HTML template view.html to display on the client side browser.
1.app.route("/view")
2.def view():
3. con = sqlite3.connect("employee.db")
4. con.row_factory = sqlite3.Row
5. cur = con.cursor()
6. cur.execute("select * from Employees")
7. rows = cur.fetchall()
8. return render_template("view.html",rows = rows)
The HTML template view.html which shows all the information on the browser is given below.
view.html
1.<!DOCTYPE html>
2.<html>
3.<head>
4. <title>List</title>
5.</head>
6.<body>
7.
8.<h3>Employee Information</h3>
9.<table border=5>
10. <thead>
11. <td>ID</td>
12. <td>Name</td>
13. <td>Email</td>
14. <td>Address</td>
15. </thead>
16.
17. {% for row in rows %}
18.
19. <tr>
20. <td>{{row["id"]}}</td>
21. <td>{{row["name"]}}</td>
22. <td>{{row["email"]}}</td>
23. <td>{{row["address"]}}</td>
24. </tr>
25.
26. {% endfor %}
27.</table>
28.<br><br>
29.
30.<a href="/">Go back to home page</a>
31.
32.</body>
33.</html>
The full python script is given below.
crud.py
1.from flask import *
2.import sqlite3
3.
4.app = Flask(__name__)
5.
6.@app.route("/")
7.def index():
8. return render_template("index.html");
9.
10.@app.route("/add")
11.def add():
12. return render_template("add.html")
13.
14.@app.route("/savedetails",methods = ["POST","GET"])
15.def saveDetails():
16. msg = "msg"
17. if request.method == "POST":
18. try:
19. name = request.form["name"]
20. email = request.form["email"]
21. address = request.form["address"]
22. with sqlite3.connect("employee.db") as con:
23. cur = con.cursor()
24. cur.execute("INSERT into Employees (name, email, address) values (?,?,?)",(name,email,address))
25. con.commit()
26. msg = "Employee successfully Added"
27. except:
28. con.rollback()
29. msg = "We can not add the employee to the list"
30. finally:
31. return render_template("success.html",msg = msg)
32. con.close()
33.
34.@app.route("/view")
35.def view():
36. con = sqlite3.connect("employee.db")
37. con.row_factory = sqlite3.Row
38. cur = con.cursor()
39. cur.execute("select * from Employees")
40. rows = cur.fetchall()
41. return render_template("view.html",rows = rows)
42.
43.
44.@app.route("/delete")
45.def delete():
46. return render_template("delete.html")
47.
48.@app.route("/deleterecord",methods = ["POST"])
49.def deleterecord():
50. id = request.form["id"]
51. with sqlite3.connect("employee.db") as con:
52. try:
53. cur = con.cursor()
54. cur.execute("delete from Employees where id = ?",id)
55. msg = "record successfully deleted"
56. except:
57. msg = "can't be deleted"
58. finally:
59. return render_template("delete_record.html",msg = msg)
60.
61.if __name__ == "__main__":
62. app.run(debug = True)
Run the python script EmployeeDB.py to create the database and the Employees table using the following command on the terminal.
1.$ python EmployeeDB.py
Now, run the flask script crud.py and visit https://localhost:5000 on the browser.
Click on the link Add Employee to add a new employee to the database.
Fill this form and click submit to save the details into the database.
Now, click on the view employee to list all the employees of the database. Till now, we have only one employee in the list as shown in the below image.
Click on the link given at the bottom of the page to go back to the home page.
Now click on the Delete Record to check how the script deletes the record for the specific employee_id.
Enter any employee id for which the records are to be deleted. Here, we must notice that if the entered Employee Id doesn't exist in the database, then an error message will be displayed. Let's enter the employee id 1 to delete the employee john from the database.
Hence, the record for the employee with id 1 is deleted. Here, we can confirm this by viewing the list. Click View List to view the list.